package cn.com.bluemoon.daps.system.mapper;


import cn.com.bluemoon.daps.system.dto.SysInfoDto;
import cn.com.bluemoon.daps.system.dto.SystemInfoDto;
import cn.com.bluemoon.daps.system.entity.DapSystemInfo;
import cn.com.bluemoon.daps.system.vo.SimpleSysInfoVo;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import org.springframework.stereotype.Repository;

import java.util.List;

/**
 * <p>
 * 系统表 Mapper 接口
 * </p>
 *
 * @author admin
 * @since 2020-08-03
 */
@Repository
public interface DapSystemInfoMapper extends BaseMapper<DapSystemInfo> {


    Page<SystemInfoDto> getSysInfoPage(Page page, @Param("sysName") String sysName, @Param("bmStatus") int bmStatus);

    /**
     * 支持系统简称和系统名查询
     *
     * @param page
     * @param sysName
     * @param bmStatus
     * @return
     */
    IPage<DapSystemInfo> selectByName(Page page, @Param("sysName") String sysName, @Param("bmStatus") int bmStatus);

    /**
     * 系统详情
     *
     * @param sysId
     * @param bmStatus
     * @return
     */
    SysInfoDto selectSysInfo(@Param("sysId") String sysId, @Param("bmStatus") Integer bmStatus);

    /**
     * 根据员工号+用户类型相关系统信息
     *
     * @param userId   用户工号
     * @param userType 用户类型对应系统人员列表：1 产品负责人、2技术负责人、3业务负责人，非必填，默认为2
     * @return 根据员工号+用户类型相关系统信息
     */
    List<SystemInfoDto> selectMapsByParam(@Param("userId") String userId, @Param("userType") Integer userType);

    @Select("select a.type as systemType,\n" +
            "       a.name as systemName,\n" +
            "       a.id   as systemId\n" +
            "from dap_system_info a\n" +
            "         inner join dap_system_datasource b on b.system_info_id = a.id and b.bm_status = 1\n" +
            "where b.database_type = #{dbType}\n" +
            "  and a.bm_status = 1")
    List<SimpleSysInfoVo> selectListByDbType(@Param("dbType") Integer dbType);
}
